// 扩展vue原有的功能：全局组件，自定义指令，挂载原型方法，注意：没有全局过滤器。
// 这就是插件
// vue2.0插件写法要素：导出一个对象，有install函数，默认传入了Vue构造函数，Vue基础之上扩展
// vue3.0插件写法要素：导出一个对象，有install函数，默认传入了app应用实例，app基础之上扩展

// 其实就是vue插件，扩展vue功能，全局组件、指令、函数 （vue.30取消过滤器）
// 当你在mian.js导入，使用Vue.use()  (vue3.0 app)的时候就会执行install函数

// 自动的批量注册组件

// // 全局注册骨架
// import TiziSkeleton from './tizi-skeleton.vue'
// // 全局注册轮播图
// import TiziCarousel from './tizi-carousel.vue'
// // 全局注册面板
// import TiziMore from './tizi-more.vue'
// // 全局注册面包屑
// import TiziBread from './tizi-bread.vue'
// // 全局注册单项面包屑
// import TiziBreadItem from './tizi-bread-item.vue'

import defaultImg from '@/assets/images/200.png'

import Message from './Message'

import Confirm from './confirm'

// 导入library文件夹下的所有组件
// 批量导入需要使用一个函数 require.context(dir,deep,matching)
// 参数：1. 目录  2. 是否加载子目录  3. 加载的正则匹配
const importFn = require.context('./', false, /\.vue$/)
    // console.dir(importFn.keys()) 文件名称数组


export default {
    install(app) {
        // 在app上进行扩展，app提供 component directive 函数
        // 如果要挂载原型 app.config.globalProperties 方式
        // app.component(TiziSkeleton.name, TiziSkeleton)
        // app.component(TiziCarousel.name, TiziCarousel)
        // app.component(TiziMore.name, TiziMore)
        // app.component(TiziBread.name, TiziBread)
        // app.component(TiziBreadItem.name, TiziBreadItem)

        // 批量注册全局组件
        importFn.keys().forEach(key => {
            // 导入组件
            const component = importFn(key).default
                // 注册组件
            app.component(component.name, component)
        })

        // 封装懒加载指令
        defineDirective(app)

        // 如果你想挂载全局的属性， 能够通过组件实例调用的属性 this.$message
        app.config.globalProperties.$message = Message // 原型函数 
        app.config.globalProperties.$confirm = Confirm
    }
}

// 定义指令
const defineDirective = (app) => {
    // 图片懒加载指令
    app.directive('lazyload', {
        mounted(el, binding) {
            const observer = new IntersectionObserver(([{ isIntersecting }]) => {
                if (isIntersecting) {
                    observer.unobserve(el)
                    el.onerror = () => {
                        el.src = defaultImg
                    }
                    el.src = binding.value
                }
            }, {
                threshold: 0.01
            })
            observer.observe(el)
        }
    })
}